# **Vivado IP Flow Demo Script**

#### Introduction

This demonstration introduces the IP flow, including:

- Upgrading IP
- Customizing IP
- Generating output products
- Instantiating IP
- Identifying the difference between the out-of-context flow (OOC) flow and global synthesis flow

## **Preparation:**

- Required files: \$TRAINING PATH/IP Flow/demo/KCU105/verilog
- Required hardware: None
- Supporting materials: None

#### **Vivado IP Flow**

| Action with Description            | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                                                                                                    |
|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Launch Vivado Design Suite 2021.2. | <ul> <li>The Getting Started page provides links to:</li> <li>Create a new project</li> <li>Open an existing project</li> <li>Open example projects</li> <li>Manage IP</li> <li>Open the hardware manager</li> <li>Visit the Xilinx Tcl Store</li> <li>View documentation and QuickTake videos for the Vivado Design Suite</li> </ul> |

|   | Action with Description                                                                                           | Point of Emphasis and Key Takeaway                                                                                                                                                                                                     | у  |
|---|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| • | Open the wave_gen.xpr project from the \$TRAINING_PATH/IP_Flow/demo/KCU105/verilog directory.                     | <ul> <li>You can easily open an existing<br/>Vivado IDE project via the Getting<br/>Started page.</li> </ul>                                                                                                                           |    |
| • | Go to <b>IP Sources</b> in the Sources window, right-click <b>clk_core</b> , and select <b>Report IP Status</b> . | <ul> <li>The IP status tab shows the device<br/>part of the IP targeted, under<br/>Current Part.</li> </ul>                                                                                                                            |    |
|   |                                                                                                                   | <ul> <li>In this demo, the clk_core IP is<br/>targeted to a Kintex® 7 series device<br/>and the project is targeted to a<br/>Kintex UltraScale™ device.</li> </ul>                                                                     | æ  |
|   |                                                                                                                   | <ul> <li>The change log for the upgraded IP<br/>can also be viewed from IP Status<br/>tab.</li> </ul>                                                                                                                                  | 1  |
| • | Right-click <b>clk_core</b> from the IP Sources tab, select <b>Upgrade IP</b> , and click <b>OK</b> .             | <ul> <li>The IP Status tab after upgrading th<br/>IP shows that the clk_core IP is<br/>up-to-date.</li> </ul>                                                                                                                          | ie |
| • | Make sure that the <b>Continue with Core Container Disabled</b> option is selected and click <b>OK</b> .          | <ul> <li>The Enable Core Container dialog box opens and prompts you if you want to enable the core container feature for the IP.</li> <li>For this demo, you do not need to enable the core container features for this IP.</li> </ul> |    |
| • | Click <b>OK</b> in the Upgrade IP dialog box.                                                                     |                                                                                                                                                                                                                                        |    |
| • | Click <b>Generate</b> in the dialog box to generate the output products for <i>clk_core</i> .                     |                                                                                                                                                                                                                                        |    |
| • | Click <b>OK</b> in the Generate Output<br>Products dialog box.                                                    |                                                                                                                                                                                                                                        |    |
| • | Click <b>OK</b> in the Critical Warnings dialog box.                                                              |                                                                                                                                                                                                                                        |    |

| Action with Description                                                                                                                         | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Rerun the IP Status report from<br/>Reports &gt; Report IP Status to<br/>notice that the clk_core IP is<br/>up-to-date now.</li> </ul> |                                                                                                                                                                                                                                                                                                           |
| Select <b>IP Catalog</b> from the Flow Navigator.                                                                                               | <ul> <li>The Vivado IP catalog provides<br/>consistent, easy access to Xilinx IP,<br/>including building blocks, wizards,<br/>connectivity, DSP, embedded, AXI<br/>infrastructure, and video IP from a<br/>single common repository<br/>regardless of the end application<br/>being developed.</li> </ul> |
|                                                                                                                                                 | <ul> <li>Note that only one version of IP (i.e.,<br/>the latest version of IP) will be<br/>available in the IP catalog.</li> </ul>                                                                                                                                                                        |
| <ul> <li>Search for and select FIFO</li> <li>Generator from the IP catalog.</li> </ul>                                                          | The IP catalog contains categories of IP that you can filter and search.                                                                                                                                                                                                                                  |
|                                                                                                                                                 | <ul> <li>You can work with the IP catalog in a<br/>variety of ways. You can search using<br/>keywords in the search box or<br/>browse through the catalog in the<br/>various categories.</li> </ul>                                                                                                       |
|                                                                                                                                                 | <ul> <li>Selecting IP will list all the details of<br/>the selected IP:</li> </ul>                                                                                                                                                                                                                        |
|                                                                                                                                                 | Name, version, types of supported interfaces, brief description of IP, IP status, etc.                                                                                                                                                                                                                    |

## **Action with Description**

- Double-click to customize the FIFO Generator IP with the following parameters:
  - Basic tab > Component Name: char\_fifo
  - FIFO Implementation:
     Independent Clocks Built-in
     FIFO
  - Native ports tab > Read Mode:
     First Word Fall Through
  - Write width: 8
  - Write depth: 2048

## **Point of Emphasis and Key Takeaway**

- The selected IP can be customized by right-clicking and selecting
   Customize IP or double -click the IP.
- In the Summary tab of the IP
   Customization dialog box you can
   verify that the information is correct
   and then generate the IP.
- Once the customization is done, the Generate Output Products dialog box opens.
- Click **OK** and click **Generate** in the dialog box to generate the output products with the default settings (OOC flow).
- Click **OK** if the Generate Output Products dialog box prompts.
- By default, the Synthesized
   Checkpoint (.dcp) is generated, and an Out-of-Context Module Run for the char\_fifo IP is added to the Design Runs window.
- The new run is created and launched to synthesize the IP.
- When the entire design is synthesized, an HDL stub module is provided in the DCP, which causes a black box to be inferred for the IP.
- This OOC flow reduces synthesis run times because the IP is synthesized only once. If the top-level design is changed and has to be synthesized, the IP is not re-synthesized.
- The synthesis log file can be viewed from the properties window by selecting the created IP run from the Design Runs window.

## **Action with Description**

# **Point of Emphasis and Key Takeaway**

In the Log table tab next to TCL Console tab, select the **char\_fifo\_synth\_1** and see the log file.



Select the **IP Sources** tab to examine the output products that are generated.



- The IP Sources window shows the generated output products.
- By default, Xilinx IP will generate:
  - Instantiation template
  - Synthesis files
    - Constraints files associated with synthesis
  - Simulation files
    - Simulation sources associated with IP
  - Change log
  - Design checkpoint (.dcp)
    - Synthesizes the IP and generates the DCP file in OOC mode
  - Simulation netlist and stub files

## **Action with Description**

# **Point of Emphasis and Key Takeaway**

- View the instantiation template that is generated for *char\_fifo*.
- Since it is already been instantiated, you can view it in the **Hierarchy** tab under the top-level file (wave\_gen).
- After the IP is generated, if the IP is not instantiated in the design it will be added at the same level as the top-level wave\_gen module in the Hierarchy tab.
- The IP has already been instantiated in the design. To view the instantiation, open the wave\_gen.v file in the text editor and observe lines 338 to 350.
- Notice that the Hierarchy, Libraries, and Compile Order tabs are updated to indicate that the IP has been instantiated into the design.
- Observe the directory structure of the generated output products for the IP.
  - Browse to the \$TRAINING\_PATH/IP\_Flow/ demo/KCU105/verilog/ wave\_gen.srcs/sources\_1/ ip directory.
  - Notice that there is one directory for each IP.

- The *clk\_core* directory contains the output products for the *clk\_core* IP.
- The char\_fifo directory contains the output products for the char\_fifo IP.

- Examine the output products for the char\_fifo IP in the IP Sources tab of the Sources view.
  - Select the **IP Sources** tab in the Sources window.
  - Expand the char\_fifo and clk\_core folders and observe that the outputs products for both IPs are the same.
- Within the Vivado IDE Sources view, the two IP appear the same, both listing the output products, all of which can be opened for viewing from within the Vivado IDE.

|   | Action with Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Point of Emphasis and Key Takeaway                                                                                                                                                                      |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Generate the output products for char_fifo by using the global synthesis flow.  • Right-click char_fifo in the IP Sources window and select Generate Output Products.  • Select the Global option in the Synthesis Options section and click Generate in the Generate the output products section.                                                                                                                                                                                | <ul> <li>Note that new design run for char_fifo is not created as in the OOC flow.</li> <li>Now, the char_fifo IP output products will be generated while synthesizing the top-level design.</li> </ul> |
| • | Synthesize the design.                                                                                                                                                                                                                                                                                                                                                                                                                                                            | The char_fifo IP gets synthesized along with the top-level design.                                                                                                                                      |
| • | Right-click the char_fifo IP and select Remove File from Project to delete the char_fifo IP from the IP Sources window.  • Also, make sure that the IP files are removed from the project directory.  Run a Tcl script to generate the char_fifo IP.  • Run the Tcl script from the Tcl Console by using the following command:  source \$::env(TRAINING_PATH)/IP _Flow/demo/KCU105/verilog/char_fifo_run.tcl  • View the Tcl script and output products generated for char_fifo. | <ul> <li>IP can be created and customized by using Tcl commands such as create_ip and set_property.</li> <li>The generate_target command is used to generate output products.</li> </ul>                |
| • | Select <b>File</b> > <b>Exit</b> to close the Vivado Design Suite.                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                         |

## **Summary**

This demonstration showed you the IP flow, use of the core container feature, and the difference between out-of-context (OOC) and global synthesis flow.

#### References:

- Supporting materials
  - Vivado Design Suite User Guide: Design with IP (UG896)
  - Using Core Containers for IP Quick Take video
     www.xilinx.com/training/vivado/using-core-containers-for-ip.htm